

# FT64F0AX SLEEP Application note



# 目录

| 1. | 睡眠模式          | . 3 |
|----|---------------|-----|
|    | 1.1. 进入 SLEEP | . 3 |
|    | 1.2. 睡眠的唤醒    | . 4 |
|    | 1.2.1. 使用中断唤醒 | . 4 |
|    | 1.3. 睡眠的系统时钟  | . 5 |
| 2. | 应用范例          | . 6 |
| 联系 | <b>信息</b>     | 11  |



# FT64F0Ax SLEEP 应用

## 1. 睡眠模式

睡眠模式下,指令时钟关闭,指令执行停止,大多数模块掉电以降低功耗。如表 1-1 所示,FT64F0Ax可根据实际需求在睡眠时有选择地开启各个模块,而无须指令介入,以使其相应功能如 LVR、LVD、WDT、Timers、PWM 和 ADC 能在 SLEEP 模式下保持运行。一些模块也可配置成进入 SLEEP 后自动关闭,而无须由指令关闭。

| 其<br>模块                                      | SLEEP 模式下的各模块配置条件                               |            |  |  |
|----------------------------------------------|-------------------------------------------------|------------|--|--|
| 1天-大                                         | 运行                                              | 自动关闭?      |  |  |
| 指令时钟                                         | (始终关闭)                                          | Yes        |  |  |
| LVR                                          | LVREN = 00 or (LVREN = 01 & SLVREN=1)           | LVREN = 10 |  |  |
| LVD                                          | LVDEN = 1                                       | No         |  |  |
| WDT                                          | WDTE or SWDTEN                                  | No         |  |  |
| TIMER1                                       | SYSON = 1 & TIM1EN = 1                          | SYSON = 0  |  |  |
| TIMER2                                       | SYSON = 1 & TIM2EN = 1                          | SYSON = 0  |  |  |
| TIMER4                                       | SYSON = 1 & TIM4EN = 1                          | SYSON = 0  |  |  |
| PWM                                          | (跟随 Timer1 或 Timer2)                            |            |  |  |
| HIRC / LIRC / EC / LP / XT                   | (跟随使用它们的外设状态)                                   |            |  |  |
| ADC                                          | (当 ADCEN = 1 & ADON = 1 且 ADC 所选时钟源保持运行时, ADC 即 |            |  |  |
| ADC                                          | 可运行)                                            |            |  |  |
| SPI                                          | (当 SPICKEN = 1 且 SPI 所选时钟源保持运行时,SPI 即可运行)       |            |  |  |
| I2C                                          | (当 I2CEN = 1 且 I2C 所选时钟源保持运行时,I2C 即可运行)         |            |  |  |
| USART1/ USART 2                              | (当 USARTxEN = 1 且 USARTx 所选时钟源保持运行时,USARTx 即    |            |  |  |
| USAKI I/ USAKI Z                             | 可运行)                                            |            |  |  |
| O (除非 SLEEP 时使能 PWM, 否则 I/O 将保持其进入 SLEEP 前的状 |                                                 |            |  |  |

表 1-1 除指令时钟外, 其他模块可根据需求在 SLEEP 模式下保持运行

#### 1.1. 进入 SLEEP

器件通过执行 SLEEP 指令进入睡眠模式。

进入休眠模式时, MCU 的状态如下:

- 1. WDT 将清零但是保持运行 (如果使能了在休眠期间工作)
- 2. STATUS 寄存器的 PD 位清零
- 3. STATUS 寄存器的 TO 位置 1
- 4. CPU 时钟停止
- 5. 32kHz LIRC 不受影响,并且由其提供时钟的外设可以在休眠模式下继续工作
- 6. LP 晶体振荡器不受影响 (当 TIMx 使用它作为工作时钟时)



- 7. ADC 不受影响 (如果选择了专用 FRC 时钟)
- 8. 电容触摸传感振荡器不受影响
- 9. I/O 端口保持执行 SLEEP 指令之前的状态 (驱动为高电平、低电平或高阻态)
- 10. WDT 之外的复位不受休眠模式影响

关于外设在休眠期间工作的更多详细信息,请参见各个章节。

要最大程度地降低电流消耗,应考虑以下条件:

- 1. I/O 引脚不应悬空, I/O 作为输入时可打开内部的上拉或下拉
- 2. 外部电路从 I/O 引脚灌电流
- 3. 内部电路从 I/O 引脚拉电流
- 4. 内部弱上拉的引脚
- 5. 模块使用 32kHz LIRC
- 6. 模块使用 LP 振荡器

#### 1.2. 睡眠的唤醒

可以通过下列任一事件将器件从休眠状态唤醒:

- 1. MCLR 引脚上的外部复位输入 (如果使能)
- 2. BOR 复位 (如果使能)
- 3. POR 复位
- 4. 看门狗定时器 (如果使能)溢出
- 5. 任何外部中断
- 6. 能够在休眠期间运行的外设产生的中断 (更多信息请参见各个外设)

前3个事件会使器件复位,后3个事件认为是程序执行的延续。

当执行 SLEEP 指令时,下一条指令 (PC+1) 被预先取出。如果希望通过中断事件唤醒器件,则必须允许相应的中断允许位。唤醒与 GIE 位的状态无关,如果 GIE 位被禁止,器件将继续执行 SLEEP 指令后的指令。如果 GIE 位被允许,器件先执行 SLEEP 指令后的指令,然后将调用中断服务程序。如果不想执行 SLEEP 指令后的指令,用户应该在 SLEEP 指令后面放置一条 NOP 指令。

器件从休眠模式唤醒时, WDT 清零, 与唤醒的原因无关。

#### 1.2.1. 使用中断唤醒

当禁止全局中断 (GIE 被清零),并且有任一中断源中断标志位置 1 且其中断被使能时,将会发生下列某一事件:

● 如果在执行 SLEEP 指令之前发生中断



- ✓ SLEEP 指令将作为 NOP 执行
- ✓ WDT 和 WDT 预分频器不会清零
- ✓ STATUS 寄存器的 TO 位不会置 1
- ✓ STATUS 寄存器的 PD 位不会清零
- 如果在执行 SLEEP 指令期间或之后发生中断
  - ✓ SLEEP 指令将完全执行
  - ✓ 器件将立即从休眠模式唤醒
  - ✓ WDT 和 WDT 预分频器将清零
  - ✓ STATUS 寄存器的 TO 位将置 1
  - ✓ STATUS 寄存器的 PD 位将清零

要确定是否执行了 SLEEP 指令, 可以测试 PD 位。如果 PD 位置 1, 则说明 SLEEP 指令被作为一条 NOP 指令执行了。

#### 1.3. 睡眠的系统时钟

进入睡眠状态后, CPU 时钟停止, PC 停留在 SLEEP 的下一条地址。默认情况下, 系统时钟也会被关闭。但如果 SYSON 位置 1 时, 系统时钟将一直保持运行, 在这种情况下, 被选择为系统时钟的 HIRC, XT, LIRC 振荡器将不会被关闭。

- 5 -

注意:如果要使用 PROM 或数据 EEPROM 的写完成中断唤醒, SYSON 必须置 1。



## 2. 应用范例

```
/* 文件名: ASM 64F0Ax SLEEP.ASM
* 功能:
      FT64F0Ax SLEEP 功能演示
* IC:
      FT64F0A5
                TSSOP20
* 内部:
      16M/4T
      此程序为 FT64F0Ax-SLEEP 睡眠演示程序,上电之后 LED1、LED2
* 说明:
      同时置高约 2s, 然后置低, 进入睡眠。测试 FT64F0Ax 的睡眠功耗
      FT64F0A5 TSSOP20
               (PA4)20|-----NC
* NC-----|1(PA5)
* NC-----|2(PA6)
               (PA3)19|----NC
               (PA2)18|----NC
* NC-----|3(PA7)
* NC-----|4(PC0)
               (PA1)17|-----LED1
* NC-----|5(PC1)
               (PA0)16|-----LED2
* NC-----|6(PB7)
               (PB0)15|----NC
* GND-----|7(GND)
               (PB1)14|----NC
* NC-----|8(PB6)
               (PB2)13|----NC
* VDD-----|9(VDD)
               (PB3)12|----NC
* NC-----|10(PB5)
               (PB4)11|----NC
*/
#INCLUDE <FT64F0AX.INC>:
;RAM DEFINE
______
            EQU
                    0X40
  TEMP
  TEMP1
            EQU
                    0X41
  TEMP2
            EQU
                    0X42
  W TMP
            EQU
                    0x43
  S TMP
                    0x44
            EQU
___________
CONSTANT DEFINE
INTCON DEF
            EQU
                    B'00000000'
                              :禁止所有中断
  OSCCON_DEF EQU
                    B'01110001'
                              ;16MHz 1:1
  WPUA DEF
                    B'00000000'
                              ;弱上拉的开关, 0-关, 1-开
            EQU
  WPUB DEF
            EQU
                    B'00000000'
  WPUC DEF
                    B'00000000'
            EQU
  WPDA DEF
                              ;弱下拉的开关, 0-关, 1-开
            EQU
                    B'00000000'
```



|                                                                                                                     | B_DEF                                               | EQU                                                                           | B'00000000'                                  |                                         |
|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------|-----------------------------------------|
| WPD                                                                                                                 | C_DEF                                               | EQU                                                                           | B'00000000'                                  |                                         |
| TRIS                                                                                                                | A_DEF                                               | EQU                                                                           | B'00000000'                                  | ;输入输出设置,0-输出,1-输入<br>;PA1-OUT,PA0-OUT   |
| TRIS                                                                                                                | B DEF                                               | EQU                                                                           | B'00000000'                                  | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |
|                                                                                                                     | C DEF                                               | EQU                                                                           | B'00000000'                                  |                                         |
|                                                                                                                     | _                                                   |                                                                               |                                              |                                         |
| PSR                                                                                                                 | C0_DEF                                              | EQU                                                                           | B'11111111'                                  | ;源电流设置最大                                |
| PSR                                                                                                                 | C1_DEF                                              | EQU                                                                           | B'11111111'                                  |                                         |
| PSR                                                                                                                 | C2_DEF                                              | EQU                                                                           | B'00001111'                                  |                                         |
| PSIN                                                                                                                | IKO DEF                                             | EQU                                                                           | B'11111111'                                  | ;灌电流设置最大                                |
|                                                                                                                     | IK1 DEF                                             |                                                                               | B'11111111'                                  | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |
|                                                                                                                     | IK2 DEF                                             | EQU                                                                           | B'00000011'                                  |                                         |
|                                                                                                                     | _                                                   |                                                                               |                                              |                                         |
|                                                                                                                     | _                                                   |                                                                               |                                              | ;设置对应的 IO 为数字 IO<br>=======             |
| ;USER I                                                                                                             | DEFINE                                              |                                                                               |                                              | ======================================= |
| #DEFINE                                                                                                             |                                                     | D1 P(                                                                         |                                              |                                         |
| #DEFINE                                                                                                             |                                                     |                                                                               | ORTA,0                                       |                                         |
| ;======                                                                                                             | :======                                             | :======:                                                                      | =========                                    | ======================================= |
| •                                                                                                                   | AM START                                            |                                                                               |                                              |                                         |
| ;======<br>ORG                                                                                                      |                                                     |                                                                               | ========                                     | ======================================= |
|                                                                                                                     | i                                                   | UXUUUU                                                                        |                                              |                                         |
| LJUN                                                                                                                |                                                     | 0x0000<br>RESTART                                                             |                                              |                                         |
| LJUN<br>ORG                                                                                                         | ИP                                                  |                                                                               |                                              |                                         |
|                                                                                                                     | ИP                                                  | RESTART                                                                       |                                              |                                         |
| ORG                                                                                                                 | MP<br>i                                             | RESTART<br>0x0004                                                             |                                              |                                         |
| ORG<br>STR                                                                                                          | MP<br>i                                             | RESTART<br>0x0004<br>W_TMP                                                    |                                              |                                         |
| ORG<br>STR<br>SWA                                                                                                   | MP<br>:<br>.PR                                      | RESTART<br>0x0004<br>W_TMP<br>STATUS,W                                        |                                              |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUM                                                                                    | MP<br>i<br>.PR<br>MP                                | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | RAM                                          |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUM<br>;======;                                                                        | MP<br>;<br>.PR<br>MP<br>:======                     | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | RAM<br>=======                               |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUN<br>;======<br>;SYSTEM<br>;======                                                   | MP<br>PR<br>MP<br>START                             | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | RAM<br>=======                               |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUM<br>;======<br>;SYSTEM<br>;=======                                                  | MP<br>;<br>.PR<br>MP<br>:=====<br>1 START<br>:===== | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | RAM<br>=======                               |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUM<br>;======<br>;SYSTEM<br>;=======<br>RESTART<br>BANI                               | MP  PR  MP  START  START  KSEL                      | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | RAM<br>=======                               |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUM<br>;======<br>;SYSTEM<br>;=======                                                  | MP  PR  MP  START  T:  KSEL  L                      | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | RAM<br>=======                               |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUM<br>;======<br>;SYSTEM<br>;======<br>RESTART<br>BANI<br>LCAL                        | MP  PR  MP  START  T:  KSEL  L                      | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | RAM<br>=======                               |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUM<br>;======<br>;SYSTEM<br>;======<br>RESTART<br>BANI<br>LCAL<br>BSR<br>NOP          | MP PR MP START START T: KSEL                        | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | RAM<br>=======                               |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUM<br>;=======<br>;SYSTEM<br>;=======<br>RESTART<br>BANI<br>LCAL<br>BSR<br>NOP<br>BSR | MP  PR  MP  START  T:  KSEL  L                      | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | :RAM<br>==================================== |                                         |
| ORG STR SWA STR LJUN ;====== ;SYSTEM ;====== RESTAR BANI LCAL BSR NOP BSR LCAL                                      | MP PR MP START START START L L                      | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG PORTA INITIAL LED1 LED2 DELAY_2S | :RAM<br>==================================== |                                         |
| ORG<br>STR<br>SWA<br>STR<br>LJUM<br>;=======<br>;SYSTEM<br>;=======<br>RESTART<br>BANI<br>LCAL<br>BSR<br>NOP<br>BSR | MP PR MP START START KSEL L                         | RESTART 0x0004 W_TMP STATUS,W S_TMP INT_PROG                                  | :RAM<br>==================================== |                                         |

- 7 -



BCR LED2

MAIN:

CLRWDT SLEEP

LJUMP MAIN

;INT PROGRAM

INT PROGRAM:

SWAPR S\_TMP,0 STR STATUS SWAPR W\_TMP,1 SWAPR W\_TMP,0

**RETI** 

;SYSTEM INITIAL

INITIAL:

BANKSEL OSCCON

LDWI OSCCON\_DEF

STR OSCCON

BANKSEL INTCON

LDWI INTCON\_DEF

STR INTCON

BANKSEL PORTA LDWI 0X00 STR PORTA STR PORTB STR PORTC

BANKSEL TRISA

LDWI TRISA DEF

STR TRISA

LDWI TRISB DEF

STR TRISB

LDWI TRISC\_DEF

STR TRISC

BANKSEL WPUA

LDWI WPUA DEF

STR WPUA

LDWI WPUB DEF



STR WPUB

LDWI WPUC\_DEF

STR WPUC

BANKSEL WPDA

LDWI WPDA\_DEF

STR WPDA

LDWI WPDB DEF

STR WPDB

LDWI WPDC\_DEF

STR WPDC

BANKSEL PSRC0

LDWI PSRC0 DEF

STR PSRC0

LDWI PSRC1 DEF

STR PSRC1

LDWI PSRC2 DEF

STR PSRC2

BANKSEL PSINK0

LDWI PSINKO\_DEF

STR PSINK0

LDWI PSINK1\_DEF

STR PSINK1

LDWI PSINK2 DEF

STR PSINK2

BANKSEL ANSELA

LDWI ANSELA DEF

STR ANSELA

BANKSEL PORTA LDWI 0X00

STR FSR0H

CLEAR\_RAM\_BANK0:

LDWI 20H STR FSR0L

CLEAR RAM BANKO LOOP:

CLRR INDF0
INCR FSR0L,F
LDWI 80H

XORWR FSR0L,W

BTSS STATUS,Z

- 9 - 2021-09-07



LJUMP CLEAR\_RAM\_BANK0\_LOOP

CLEAR\_RAM\_BANK1:

LDWI 0A0H
STR FSR0L
CLEAR RAM BANK1 LOOP:

CLRR INDF0
INCR FSR0L,F
LDWI 00H
XORWR FSR0L,W
BTSS STATUS,Z

LJUMP CLEAR\_RAM\_BANK1\_LOOP

INCR FSR0H,F

CLEAR\_RAM\_LOOP:

LDWI 10

SUBWR FSR0H,W BTSS STATUS,0

LJUMP CLEAR\_RAM\_BANK0

**RET** 

;DELAY\_2S(16M/4T, 实测为 1.97s)

DELAY\_2S:

LDWI H'C8' STR TEMP

DELAY 2S LOOP1:

LDWI H'C8' STR TEMP1

DELAY\_2S\_LOOP2:

LDWI H'30' STR TEMP2

DELAY\_2S\_LOOP3:

**CLRWDT** 

DECRSZ TEMP2,F

LJUMP DELAY\_2S\_LOOP3

DECRSZ TEMP1,F

LJUMP DELAY\_2S\_LOOP2

DECRSZ TEMP,F

LJUMP DELAY\_2S\_LOOP1

RET

**END** 



### 联系信息

#### Fremont Micro Devices (SZ) Corporation

#5-8, 10/F, Changhong Building Ke-Ji Nan 12 Road, Nanshan District, Shenzhen, Guangdong, PRC 518057

Tel: (+86 755) 8611 7811 Fax: (+86 755) 8611 7810

#### Fremont Micro Devices (HK) Corporation

#16, 16/F, Block B, Veristrong Industrial Centre, 34–36 Au Pui Wan Street, Fotan, Shatin, Hong Kong SAR

Tel: (+852) 2781 1186 Fax: (+852) 2781 1144

http://www.fremontmicro.com/

- 11 -

2021-09-07

<sup>\*</sup> Information furnished is believed to be accurate and reliable. However, Fremont Micro Devices (SZ) Corporation assumes no responsibility for the consequences of use of such information or for any infringement of patents of other rights of third parties, which may result from its use. No license is granted by implication or otherwise under any patent rights of Fremont Micro Devices (SZ) Corporation. Specifications mentioned in this publication are subject to change without notice. This publication supersedes and replaces all information previously supplied. Fremont Micro Devices (SZ) Corporation products are not authorized for use as critical components in life support devices or systems without express written approval of Fremont Micro Devices (SZ) Corporation. The FMD logo is a registered trademark of Fremont Micro Devices (SZ) Corporation. All other names are the property of their respective owners.